Latest Date of Dataset: 2020-04-17
Updated: 2020-04-18 19:43:34 EST
This dashboard is used to track the current progress of the COVID-19 pandemic throughout the world. The visualization and information presented are automatically updated daily with current data scraped from the Johns Hopkin’s COVID-19 Data Repository. Their data is retrieved from offical sources such as World Health Organization (WHO), China CDC, US CDC, and more.
The data is cleaned and aggregated through R, formatted in Rmarkdown, and exported as an HTML document to be hosted through GitPages. The source R notebook can be found at covid19-daily-dashboard.Rmd in the GitHub repository.
Overview of Cases (2020-04-17)
Below is an interactive plot displaying the number of confirmed, dead, and recovered cases per country and province if data is specified. The data was aggregated from the Johns Hopkins’s data repository and this notebook is set to run nightly to provide up to date results
NaNs produced
Confirmed Cases per Country
The table below shows aggregated data of each country’s confirmed, recovered, and dead population. Each column can be sorted to view least or most of each status. The graphs below show the total and daily count of confirmed cases for the countries with the most cases and are tracked by days since the first reported case. Each graph has two seperate views - one with total count and another with % of country’s population. The population data is retrived from the United Nations.
(*China’s data is removed since dataset does not track prior to 22Jan20 therefore does not align with other countries)
COVID19 Cases Spread Timelapse
The time-lapse was produced through gganimate and shows the spread of the virus since 22Jan2020. The time-lapse cycles through the dates, showing the color coded increase of confirmed, recovered, and death cases across the world.

New Cases of the Day (2020-04-17)
The ‘New Cases of the Day’ map displays all confirmed cases of the specified date. The map was produced through Leaflet and provides a detailed and interactive map that shows the location and number of cases of the day.
Also, to differentiate if the case of the day is the first case in the specified location, it is highlighted red. All the specified points on the map are listed in the table below, including cumulative count of each location.
New Cases of the Week (2020-04-17)
The ‘New Cases of the Week’ map displays all confirmed cases of the week starting from the specified date. This map shows the same information as the daily cases map but includes all cases in the past week.
General Trends
The plots below outlines general trends seen of the virus over time:
“Percent of Cases Recovered or Dead per Day”: the total percent of cases that have resulted in recovery or death per confirmed case
“Cumulative Status of All Cases”: the continuous increase of confirmed, death, and recovered cases over time
“Status of Cases per Day”: the number of cases classified as confirmed, death, or recovered subtracted to show per day changes



---
title: "COVID19 Daily Dashboard"
output: html_notebook
    
---

```{r Setup, echo=FALSE, message=FALSE, warning=FALSE, include=FALSE}
# Interaction
library(rvest)
library(rstudioapi)
library(drat)
library(git2r)

# Aggregation
library(readr)
library(tidyr)
library(dplyr)
library(DT)

# Visualizations
library(ggplot2)
library(leaflet)
library(ggthemes)
library(gganimate)
library(maps)
library(png)
library(gifski)
library(plotly)
library(randomcoloR)
```


```{r, echo=FALSE, message=FALSE, warning=FALSE, results='hide'}
link <- "https://github.com//CSSEGISandData/COVID-19/raw/master/csse_covid_19_data/csse_covid_19_time_series/"
csv_list <- c(
  "time_series_covid19_confirmed_global.csv",
  "time_series_covid19_deaths_global.csv",
  "time_series_covid19_recovered_global.csv"
)


for (csv in csv_list) {
  path <- paste(link, csv, sep = "")
  download_path <- paste("data_raw/", csv, sep = "")
  download.file(path, destfile = download_path)
}
```

```{r, echo=FALSE, message=FALSE, warning=FALSE}
cv_con <- read_csv("data_raw/time_series_covid19_confirmed_global.csv") %>%
  gather(key = "Date", value = Confirmed, -Lat, -Long, -`Province/State`, -`Country/Region`)

cv_ded <- read_csv("data_raw/time_series_covid19_deaths_global.csv") %>%
  gather(key = "Date", value = Dead, -Lat, -Long, -`Province/State`, -`Country/Region`)

cv_rec <- read_csv("data_raw/time_series_covid19_recovered_global.csv") %>%
  gather(key = "Date", value = Recovered, -Lat, -Long, -`Province/State`, -`Country/Region`)

country_pop <- read_csv("data_raw/country_population.csv")
```


```{r, echo=FALSE, message=FALSE, warning=FALSE}
cv_merge <- merge(cv_con, cv_ded, by = c("Province/State", "Lat", "Long", "Country/Region", "Date"), all = TRUE) %>%
  merge(cv_rec, by = c("Province/State", "Lat", "Long", "Country/Region", "Date"), all = TRUE) %>%
  rename("Country_Region" = "Country/Region") %>%
  rename("Province_State" = "Province/State")
cv_merge$Date <- as.Date(cv_merge$Date, format = "%m/%d/%y")

cv <- gather(cv_merge, key = "Status", value = Count, -Date, -Lat, -Long, -Province_State, -Country_Region)
cv <- cv[with(cv, order(Country_Region, Province_State, Status, Date)), ]
```



```{r function_check_first_case, echo=FALSE, message=FALSE, warning=FALSE}
check_continuous <- function(x, cv, num_prev) {
  if (
    (cv$Long[x] != cv$Long[x - num_prev]) ||
      (cv$Lat[x] != cv$Lat[x - num_prev]) ||
      (cv$Status[x] != cv$Status[x - num_prev])) {
    cont <- "N"
  }
  else {
    cont <- "Y"
  }
  return(cont)
}


daily_weekly_counter <- function(cv) {
  for (x in seq(1, nrow(cv))) {
    if (x == 1) {
      cv$Daily_Count[x] <- NA
      cv$Weekly_Count[x] <- NA
    }
    else if (check_continuous(x, cv, 1) == "N") {
      cv$Daily_Count[x] <- NA
      cv$Weekly_Count[x] <- NA
    }
    else if (x <= 7) {
      cv$Daily_Count[x] <- (cv$Count[x]) - (cv$Count[x - 1])
      cv$Weekly_Count[x] <- NA
    }
    else if ((check_continuous(x, cv, 1) == "Y") &&
      (check_continuous(x, cv, 7) == "N")) {
      cv$Daily_Count[x] <- (cv$Count[x]) - (cv$Count[x - 1])
      cv$Weekly_Count[x] <- NA
    }
    else if ((check_continuous(x, cv, 7) == "Y")) {
      cv$Daily_Count[x] <- (cv$Count[x]) - (cv$Count[x - 1])
      cv$Weekly_Count[x] <- (cv$Count[x]) - (cv$Count[x - 7])
    }
  }
  return(cv)
}
```


```{r, apply_check_case, echo=FALSE, message=FALSE, warning=FALSE}
cv <- daily_weekly_counter(cv)
latest_date <- as.Date(Sys.Date()) - 1
#latest_date <- sort(cv$Date, decreasing = TRUE)[1] - 1
cv <- filter(cv, Date <= latest_date)
```

##### Latest Date of Dataset: `r latest_date`
###### Updated: `r Sys.time()` EST

This dashboard is used to track the current progress of the COVID-19 pandemic throughout the world. The visualization and information presented are automatically updated daily with current data scraped from the [Johns Hopkin’s COVID-19 Data Repository](https://github.com/CSSEGISandData/COVID-19). Their data is retrieved from offical sources such as World Health Organization (WHO), China CDC, US CDC, and more.

The data is cleaned and aggregated through R, formatted in Rmarkdown, and exported as an HTML document to be hosted through GitPages. The source R notebook can be found at [covid19-daily-dashboard.Rmd](https://github.com/albechen/covid19-daily-dashboard/blob/master/covid19-daily-dashboard.Rmd) in the [GitHub repository](https://github.com/albechen/covid19-daily-dashboard).


```{r empty_df_function, echo=FALSE, message=FALSE, warning=FALSE}
empty_df <- function() {
  empty_df <- data.frame(
    Province_State = character(0),
    Lat = double(), Long = double(),
    Country_Region = character(0),
    Date = as.Date(character()),
    Status = character(0),
    Count = double(),
    Daily_Count = double(), Weekly_Count = double()
  )
  empty_df$Province_State <- as.character(empty_df$Province_State)
  empty_df$Country_Region <- as.character(empty_df$Country_Region)
  empty_df$Status <- as.character(empty_df$Status)
  return(empty_df)
}
```


```{r new_cases_agg, echo=FALSE, message=FALSE, warning=FALSE}
first_and_new_cases <- function(cv, days) {
  high_date <- sort(cv$Date, decreasing = TRUE)[1] - 1
  cv <- cv %>% 
    filter(Status == "Confirmed", !is.na(Count))
  cv$First_Case <- FALSE

  for (x in seq(1, nrow(cv))) {
    if (
      (cv$Date[x] == high_date) &&
        (cv$Count[x - days] == 0) &&
        (cv$Count[x] > 0)
    ) {
      cv$First_Case[x] <- TRUE
    }
  }

  new_cases_df <- filter(cv, Date == high_date)

  if (days == 1) {
    new_cases_df <- filter(new_cases_df, Daily_Count > 0)
  }
  else if (days == 7) {
    new_cases_df <- filter(new_cases_df, Weekly_Count > 0)
  }

  return(new_cases_df)
}

new_cases_day <- first_and_new_cases(cv, 1)
new_cases_week <- first_and_new_cases(cv, 7)
```


```{r, echo=FALSE}
cv_latest <- filter(cv_merge, Date == latest_date)
cv_latest <- cv_latest[with(cv_latest, order(-Confirmed, -Recovered, -Dead)), ]
```

### Overview of Cases (`r latest_date`)
Below is an interactive plot displaying the number of confirmed, dead, and recovered cases per country and province if data is specified. The data was aggregated from the Johns Hopkins's data repository and this notebook is set to run nightly to provide up to date results
```{r full_plot, echo=FALSE}
cv_latest_labels <- function(df) {
  labs <- lapply(seq(nrow(df)), function(i) {
    paste0(
      "Country: ", df[i, "Country_Region"], "<br> ",
      "Province: ", df[i, "Province_State"], "<br>",
      "Confirmed: ", df[i, "Confirmed"], "<br>",
      "Dead: ", df[i, "Dead"], "<br>",
      "Recovered: ", df[i, "Recovered"], "<br>",
      "Date: ", df[i, "Date"]
    )
  })
}

leaflet(data = cv_latest, width = "100%") %>%
  addTiles() %>%
  addCircleMarkers(
    lat = ~Lat,
    lng = ~Long,
    radius = ~ log(Confirmed, 1.1)/10,
    label = lapply(cv_latest_labels(cv_latest), htmltools::HTML)
  )
```


### Confirmed Cases per Country
The table below shows aggregated data of each country's confirmed, recovered, and dead population. Each column can be sorted to view least or most of each status. The graphs below show the total and daily count of confirmed cases for the countries with the most cases and are tracked by days since the first reported case. Each graph has two seperate views - one with total count and another with % of country's population. The population data is retrived from the [United Nations](https://population.un.org/wpp/Download/Standard/CSV/).



(*China's data is removed since dataset does not track prior to 22Jan20 therefore does not align with other countries)


```{r country_table, echo=FALSE}
country_table <- cv_merge %>%
  select(Country_Region, Confirmed, Recovered, Dead, Date) %>%
  group_by(Country_Region) %>%
  filter(Date==latest_date) %>%
  select(Country_Region, Confirmed, Recovered, Dead) %>%
  summarise_all(sum)
country_table <- country_table[with(country_table, order(-Confirmed, -Recovered, -Dead)), ]

country_table
```

```{r df_for_top_countries, echo=FALSE}
top_10_countries <- (head(country_table$Country_Region, 10))

top10_df <- cv %>%
  filter((cv$Country_Region %in% c(top_10_countries)) & (cv$Status == 'Confirmed'), (cv$Country_Region != 'China')) %>%
  select(Country_Region, Date, Count, Daily_Count, Weekly_Count) %>%
  group_by(Country_Region, Date) %>%
  summarise(Count = sum(Count, na.rm = TRUE), Daily_Count = sum(Daily_Count, na.rm = TRUE), Weekly_Count = sum(Weekly_Count, na.rm = TRUE))


top10_df <- top10_df[with(top10_df, order(Country_Region, Date)), ]
top10_df$`Days Since First Case` <- 0

for (x in seq(2, nrow(top10_df))) {
  if ((top10_df$Country_Region[x] == top10_df$Country_Region[x-1]) & (top10_df$Count[x] >= 25)) {
    if (top10_df$`Days Since First Case`[x-1] == 0){
      if (top10_df$Daily_Count[x] > 0) {
        top10_df$`Days Since First Case`[x] <- 1
      }
    }
    else {
      interval <- top10_df$`Days Since First Case`[x-1]
      top10_df$`Days Since First Case`[x] <- 1 + interval
    }
  }
}


top10_df <- merge(top10_df,country_pop,by=c('Country_Region','Country_Region'))
top10_df$P_Count <- top10_df$Count / top10_df$Population
top10_df$P_Daily_Count <- top10_df$Daily_Count / top10_df$Population
top10_df$P_Weekly_Count <- top10_df$Weekly_Count / top10_df$Population
top10_df <- top10_df %>% select(Country_Region, Date, Count,  P_Count, Daily_Count, P_Daily_Count, Weekly_Count, P_Weekly_Count, `Days Since First Case`)
top10_df <- top10_df[with(top10_df, order(Country_Region, Date)), ]

```

```{r total_plotly, echo=FALSE, warning=FALSE, fig.width=10, fig.height=6}
top10_df_wide_p_count <- top10_df %>%
  filter(`Days Since First Case` != 0) %>%
  select(Country_Region, P_Count, `Days Since First Case`) %>%
  spread(key=Country_Region, value=P_Count)

top10_df_wide_count <- top10_df %>%
  filter(`Days Since First Case` != 0) %>%
  select(Country_Region, Count, `Days Since First Case`) %>%
  spread(key=Country_Region, value=Count)


palette <- distinctColorPalette(20)

fig <- top10_df_wide_count %>% plot_ly()

for (k in 2:length(top_10_countries)) {
  country_df <- data.frame(y=top10_df_wide_count[[k]], x=top10_df_wide_count[[1]])
  fig <- add_trace(fig, y=~y, x=~x, data=country_df, type="scatter", mode="lines", name = colnames(top10_df_wide_count)[k], visible = F, color = palette[k])
  
  p_country_df <- data.frame(y=top10_df_wide_p_count[[k]], x=top10_df_wide_p_count[[1]])
  fig <- add_trace(fig, y=~y, x=~x, data=p_country_df, type="scatter", mode="lines", name = colnames(top10_df_wide_p_count)[k], color = palette[k])
}

fig <- fig %>% layout(
    title = "Total Confirmed Cases Since First 25 Cases",
    xaxis = list(title='Days Since First 25 Cases'),
    yaxis = list(title = "Total Count (% or #)"),
    updatemenus = list(
      list(
        y = 0.8,
        buttons = list(

          list(method = "restyle",
               args = list("visible", c(rep(list(FALSE, TRUE), 15))),
               label = "Percent Count"),

          list(method = "restyle",
               args = list("visible", c(rep(list(TRUE, FALSE), 15))),
               label = "Total Count")
        )
        )
      )
    )

fig
```

```{r weekly_plotly, echo=FALSE, warning=FALSE, fig.width=10, fig.height=6}
top10_df_wide_p_weekly <- top10_df %>%
  filter(`Days Since First Case` != 0) %>%
  select(Country_Region, P_Weekly_Count, `Days Since First Case`) %>%
  spread(key=Country_Region, value=P_Weekly_Count)

top10_df_wide_weekly <- top10_df %>%
  filter(`Days Since First Case` != 0) %>%
  select(Country_Region, Weekly_Count, `Days Since First Case`) %>%
  spread(key=Country_Region, value=Weekly_Count)


palette <- distinctColorPalette(20)

fig <- top10_df_wide_weekly %>% plot_ly()

for (k in 2:length(top_10_countries)) {
  country_df <- data.frame(y=top10_df_wide_weekly[[k]], x=top10_df_wide_weekly[[1]])
  fig <- add_trace(fig, y=~y, x=~x, data=country_df, type="scatter", mode="lines", name = colnames(top10_df_wide_weekly)[k], visible = F, color = palette[k])
  
  p_country_df <- data.frame(y=top10_df_wide_p_weekly[[k]], x=top10_df_wide_p_weekly[[1]])
  fig <- add_trace(fig, y=~y, x=~x, data=p_country_df, type="scatter", mode="lines", name = colnames(top10_df_wide_p_weekly)[k], color = palette[k])
}

fig <- fig %>% layout(
    title = "Weekly Confirmed Cases Since First 25 Cases",
    xaxis = list(title='Days Since First 25 Cases'),
    yaxis = list(title = "Weekly Count (% or #)"),
    updatemenus = list(
      list(
        y = 0.8,
        buttons = list(

          list(method = "restyle",
               args = list("visible", c(rep(list(FALSE, TRUE), 15))),
               label = "Percent Count"),

          list(method = "restyle",
               args = list("visible", c(rep(list(TRUE, FALSE), 15))),
               label = "Total Count")
        )
        )
      )
    )

fig
```



```{r daily_plotly, echo=FALSE, warning=FALSE, fig.width=10, fig.height=6}  

top10_df_wide_p_daily <- top10_df %>%
  filter(`Days Since First Case` != 0) %>%
  select(Country_Region, P_Daily_Count, `Days Since First Case`) %>%
  spread(key=Country_Region, value=P_Daily_Count)

top10_df_wide_daily <- top10_df %>%
  filter(`Days Since First Case` != 0) %>%
  select(Country_Region, Daily_Count, `Days Since First Case`) %>%
  spread(key=Country_Region, value=Daily_Count)


palette <- distinctColorPalette(20)

fig <- top10_df_wide_daily %>% plot_ly()

for (k in 2:length(top_10_countries)) {
  country_df <- data.frame(y=top10_df_wide_daily[[k]], x=top10_df_wide_daily[[1]])
  fig <- add_trace(fig, y=~y, x=~x, data=country_df, type="scatter", mode="lines", name = colnames(top10_df_wide_daily)[k], visible = F, color = palette[k])
  
  p_country_df <- data.frame(y=top10_df_wide_p_daily[[k]], x=top10_df_wide_p_daily[[1]])
  fig <- add_trace(fig, y=~y, x=~x, data=p_country_df, type="scatter", mode="lines", name = colnames(top10_df_wide_p_daily)[k], color = palette[k])
}

fig <- fig %>% layout(
    title = "Daily Confirmed Cases Since First 25 Cases",
    xaxis = list(title='Days Since First 25 Cases'),
    yaxis = list(title = "Daily Count (% or #)"),
    updatemenus = list(
      list(
        y = 0.8,
        buttons = list(

          list(method = "restyle",
               args = list("visible", c(rep(list(FALSE, TRUE), 15))),
               label = "Percent Count"),

          list(method = "restyle",
               args = list("visible", c(rep(list(TRUE, FALSE), 15))),
               label = "Total Count")
        )
        )
      )
    )

fig
```

### COVID19 Cases Spread Timelapse

The time-lapse was produced through gganimate and shows the spread of the virus since 22Jan2020. The time-lapse cycles through the dates, showing the color coded increase of confirmed, recovered, and death cases across the world.

```{r timelaps_cases, echo=FALSE, message=FALSE, warning=FALSE, error=FALSE, results='hide', include=FALSE}
p <- ggplot() +
  borders("world", colour = "white", fill = "gray85") +
  coord_map(xlim = c(-180, 180), ylim = c(-55, 70)) +
  theme_map() +
  geom_point(data = filter(cv, Date<=latest_date), aes(x = Long, y = Lat, size = log2(Count), color = Status), alpha = 0.25) +
  scale_size_continuous(range = c(1, 15)) +
  scale_color_manual(values = c("blue", "red", "green")) +
  labs(title = "COVID19 Log Count of Cases (Date: {frame_time})", size = "Log(Cases)") +
  theme(
    plot.title = element_text(size =25, face = "bold"),
    legend.text = element_text(size = 15),
    legend.title = element_text(size = 17, face = "bold")
  ) +
  guides(color = guide_legend(override.aes = list(size = 5)), size = "none") +
  transition_time(Date) +
  enter_fade() +
  exit_fade() +
  ease_aes("linear")

days = as.numeric(latest_date - as.Date("2020-01-22"))

anim_save("covid19_timelapse.gif", p, height = 600, width = 1000, fps = 10, nframes = days*2, end_pause = 30)
```
![](covid19_timelapse.gif)

### New Cases of the Day (`r latest_date`)

The 'New Cases of the Day' map displays all confirmed cases of the specified date. The map was produced through Leaflet and provides a detailed and interactive map that shows the location and number of cases of the day.

Also, to differentiate if the case of the day is the first case in the specified location, it is highlighted red. All the specified points on the map are listed in the table below, including cumulative count of each location.


```{r day_leafly_plot, echo=FALSE, warning=FALSE}
first_color <- colorFactor(palette = c("red", "blue"), levels = c(TRUE, FALSE))

new_day_labels <- function(df) {
  labs <- lapply(seq(nrow(df)), function(i) {
    paste0(
      "Country: ", df[i, "Country_Region"], "<br> ",
      "Province: ", df[i, "Province_State"], "<br>",
      "Day Count: ", df[i, "Daily_Count"], "<br>",
      "First Case: ", df[i, "First_Case"], "<br>",
      "Date: ", df[i, "Date"]
    )
  })
}

leaflet(data = new_cases_day, width = "100%") %>%
  addTiles() %>%
  addCircleMarkers(
    lat = ~Lat,
    lng = ~Long,
    radius = ~ log(Count) / 1.25,
    label = lapply(new_day_labels(new_cases_day), htmltools::HTML),
    color = ~ first_color(First_Case)
  ) %>%
  addLegend("bottomright",
    pal = first_color, values = ~First_Case,
    title = "First Case (Day)",
    opacity = 0.75
  )
```

```{r day_table_new, echo=FALSE}
df_new_cases_day <- new_cases_day %>%
  select(
    Date, Country_Region, Province_State,
    Count, Daily_Count, Weekly_Count, First_Case
  )
df_new_cases_day
```

### New Cases of the Week (`r latest_date`)

The 'New Cases of the Week' map displays all confirmed cases of the week starting from the specified date. This map shows the same information as the daily cases map but includes all cases in the past week.

```{r week_leafly_plot, echo=FALSE}
first_color <- colorFactor(palette = c("red", "blue"), levels = c(TRUE, FALSE))

new_week_labels <- function(df) {
  labs <- lapply(seq(nrow(df)), function(i) {
    paste0(
      "Country: ", df[i, "Country_Region"], "<br> ",
      "Province: ", df[i, "Province_State"], "<br>",
      "Week Count: ", df[i, "Weekly_Count"], "<br>",
      "First Case: ", df[i, "First_Case"], "<br>",
      "Date: ", df[i, "Date"]
    )
  })
}

leaflet(data = new_cases_week, width = "100%") %>%
  addTiles() %>%
  addCircleMarkers(
    lat = ~Lat,
    lng = ~Long,
    radius = ~ log(Count) / 1.25,
    label = lapply(new_week_labels(new_cases_week), htmltools::HTML),
    color = ~ first_color(First_Case)
  ) %>%
  addLegend("bottomright",
    pal = first_color, values = ~First_Case,
    title = "First Case (Week)",
    opacity = 0.75
  )
```

```{r week_table_new, echo=FALSE}
df_new_cases_week <- new_cases_week %>%
  select(
    Date, Country_Region, Province_State,
    Count, Daily_Count, Weekly_Count, First_Case
  )
df_new_cases_week
```

```{r cases_count_percent_agg, echo=FALSE, message=FALSE, warning=FALSE, error=FALSE, include=FALSE}
percent_count <- cv_merge %>%
  group_by(Date) %>%
  filter(Date <= latest_date) %>%
  summarise(
    Confirmed = sum(Confirmed, na.rm = TRUE),
    Dead = sum(Dead, na.rm = TRUE),
    Recovered = sum(Recovered, na.rm = TRUE)
  )
for (x in seq(1, nrow(percent_count))) {
  if (x == 1) {
    percent_count$Daily_Confirmed[x] <- percent_count$Confirmed[x]
    percent_count$Daily_Dead[x] <- percent_count$Dead[x]
    percent_count$Daily_Recovered[x] <- percent_count$Recovered[x]
  }
  else {
    percent_count$Daily_Confirmed[x] <- percent_count$Confirmed[x] - percent_count$Confirmed[x - 1]
    percent_count$Daily_Dead[x] <- percent_count$Dead[x] - percent_count$Dead[x - 1]
    percent_count$Daily_Recovered[x] <- percent_count$Recovered[x] - percent_count$Recovered[x - 1]
  }
}

dead_conf_recv <- percent_count %>%
  select(Date, Confirmed, Dead, Recovered) %>%
  gather(key="Status", value="Count", -Date)

dead_conf_recv_daily <- percent_count %>%
  select(Date, Daily_Confirmed, Daily_Dead, Daily_Recovered) %>%
  gather(key="Daily", value="Count", -Date)

percent_count$Percent_Dead <- percent_count$Dead / percent_count$Confirmed

percent_count$Percent_Recovered <- percent_count$Recovered / percent_count$Confirmed

percent_org <- percent_count %>%
  select(Date, Percent_Recovered, Percent_Dead) %>%
  gather(key="Status", value="Percent", -Date) 
```

### General Trends

The plots below outlines general trends seen of the virus over time:

(1)	“Percent of Cases Recovered or Dead per Day”: the total percent of cases that have resulted in recovery or death per confirmed case

(2)	"Cumulative Status of All Cases": the continuous increase of confirmed, death, and recovered cases over time 

(3)	“Status of Cases per Day”: the number of cases classified as confirmed, death, or recovered subtracted to show per day changes

```{r plot_percent_cases, echo=FALSE, fig.width=6, fig.height=4.5}
ggplot(percent_org, aes(x = Date, y=Percent, group=Status)) +
  geom_line(aes(color = Status), size=1.3) +
  ggtitle("Percent of Cases Recovered or Dead per Day") +
  scale_color_manual(values = c("red3", "green3")) +
  scale_x_date(date_breaks = "7 day", 
               date_minor_breaks = "7 day", 
               date_labels = "%b %d") +
  theme_light() +
  theme(legend.position="bottom", legend.title = element_blank())
```

```{r plot_cumulative_status, echo=FALSE, fig.width=6, fig.height=4.5}
ggplot(dead_conf_recv, aes(x = Date, y=Count, group=Status)) +
  geom_line(aes(color = Status), size=1.3) +
  ggtitle("Cumulative Status of All Cases") +
  scale_color_manual(values = c("blue3", "red3", "green3")) +
  scale_x_date(date_breaks = "7 day", 
               date_minor_breaks = "7 day", 
               date_labels = "%b %d") +
  theme_light() +
  theme(legend.position="bottom", legend.title = element_blank())
```


```{r plot_status_per_day, echo=FALSE, fig.width=6, fig.height=4.5}  
ggplot(dead_conf_recv_daily, aes(x = Date, y=Count, group=Daily)) +
  geom_line(aes(color = Daily), size=1.3) +
  ggtitle("Status of Cases per Day") +
  scale_color_manual(values = c("blue3", "red3", "green3")) +
  scale_x_date(date_breaks = "7 day", 
               date_minor_breaks = "7 day", 
               date_labels = "%b %d")+
  theme_light() +
  theme(legend.position="bottom", legend.title = element_blank())
```

```{r github_pushing_commands, include=FALSE}
gitstatus <- function(dir = getwd()) {
  cmd_list <- list(
    cmd1 = tolower(substr(dir, 1, 2)),
    cmd2 = paste("cd", dir),
    cmd3 = "git status"
  )
  cmd <- paste(unlist(cmd_list), collapse = " & ")
  shell(cmd)
}

gitadd <- function(dir = getwd()) {
  cmd_list <- list(
    cmd1 = tolower(substr(dir, 1, 2)),
    cmd2 = paste("cd", dir),
    cmd3 = "git add --all"
  )
  cmd <- paste(unlist(cmd_list), collapse = " & ")
  shell(cmd)
}

gitcommit <- function(msg = paste("chore: auto-update", Sys.time(), "est"), dir = getwd()) {
  cmd <- sprintf("git commit -m\"%s\"", msg)
  system(cmd)
}

gitpush <- function(dir = getwd()) {
  cmd_list <- list(
    cmd1 = tolower(substr(dir, 1, 2)),
    cmd2 = paste("cd", dir),
    cmd3 = "git push"
  )
  cmd <- paste(unlist(cmd_list), collapse = " & ")
  shell(cmd)
}

git2r::config(user.name = "albechen", user.email = "alchen244@gmail.com")
```

```{r save_doc, include=FALSE}
documentSave(getActiveDocumentContext())
Sys.sleep(20)
```

```{r github_push_all, include=FALSE}
gitstatus()
gitadd()
gitcommit()
gitpush()
```
